package com.analysis.mapper;

import com.analysis.entity.Project;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

@Mapper
public interface ProjectMapper {
    
    /**
     * 插入项目
     */
    int insert(Project project);
    
    /**
     * 根据ID删除项目（逻辑删除）
     */
    int deleteById(@Param("id") Long id);
    
    /**
     * 更新项目
     */
    int update(Project project);
    
    /**
     * 根据ID查询项目
     */
    Project selectById(@Param("id") Long id);
    
    /**
     * 根据公司ID查询所有项目
     */
    List<Project> selectByCompanyId(@Param("companyId") Long companyId);
    
    /**
     * 分页查询项目（按公司）
     */
    List<Project> selectByPage(@Param("companyId") Long companyId, @Param("offset") int offset, @Param("limit") int limit);
    
    /**
     * 统计公司项目数量
     */
    int countByCompanyId(@Param("companyId") Long companyId);
    
    /**
     * 根据公司ID和项目名称查询项目（用于唯一性检查）
     */
    Project selectByCompanyIdAndProjectName(@Param("companyId") Long companyId, @Param("projectName") String projectName);
    
    /**
     * 根据公司ID查询当前选中的项目
     */
    Project selectSelectedByCompanyId(@Param("companyId") Long companyId);
    
    /**
     * 取消公司所有项目的选中状态
     */
    int unselectAllByCompanyId(@Param("companyId") Long companyId);
    
    /**
     * 设置指定项目为选中状态
     */
    int selectProject(@Param("id") Long id);
}
